5 Mayıs 2021 Çarşamba

08:02

# **05 DAC**

## **Giriş**

- DAC, "Digital-to-Analog Converter" dijital sinyalleri analog sinyallere dönüştürmek için kullanılır. Genellikle mikrodenetleyiciler, bilgisayarlar, ses sistemleri ve diğer dijital cihazlar gibi dijital veri kaynaklarından gelen dijital verileri, analog çıkış cihazlarına (örneğin hoparlörler veya ses sistemleri) uygun bir şekilde aktarmak için kullanılırlar.
- STM32F407, 0-3.3 V arasında tüm gerilimleri çıkış olarak vermemizi sağlar.
- STM32F407 mikrodenetleyicisi içerisinde dahili olarak 12 bit tampona sahip, iki adet DAC birimi bulunur. Bu birimler sayesinde dijital bir veriyi analog bir veriye dönüştürerek çıkış üretilebilir.
- STM32F407'ye ait DAC birimleri 8 bit veya 12 bit değerinde çıkış üretilebilirler.
- 12 bit değerinde kullanılırken, veri 16 bitlik kaydedici içerisinde sola veya sağa dayalı şekilde kullanılabilir.
- DAC biriminin önemli özelliklerinden bir tanesi, gürültü veya sinyali üretebilme özelliğidir.
- Üçgen dalga üretebilme özelliğine sahiptir.
- DAC birimleri APB1 veri yoluna bağlıdır, kullanmak için aktif etmek gereklidir.
- DAC için hangi pin/pinler kullanılacaksa ilgili pin/pinler GPIOA->CRL registerından analog moda alınmalıdır.

## Çözünürlük

 STM32'de DAC çözünürlüğünü arttırmak için Vref+ girişi bulunmaktadır fakat bu pin yüksek işlemcilerde bulunmaktadır. Vref+ ve Vref- pini bulunmayan işlemcilerde bu pinler dahili olarak VDDA ve VSSA' ya bağlıdır. VDDA ve VSSA ise VDD ile VSS'ye bağlanması zorunludur. Buradanda Vref+ geriliminin besleme gerilimini geçemeyeceğini anlıyoruz.

## DACoutput = Vref x DOR / 4096

- Yukarıdaki ifade ile DAC çıkış voltajı hesaplanır. Biz DAC değerlerimizi DHR registerina yazarız ve tetikleme sonucunda DHR'deki veri DOR registerina aktarılır, DOR registerini sadece okuyabiliriz.
- 12 bitlik çözünürlüğe sahip bir DAC biriminin referans gerilimleri Vssa = 0 V, Vdda = +3 V ele alınır ise, adım başına üreteceği voltaj şu şekilde hesaplanır; DACoutput = Vref/4095
  Buradan adım başına düşen voltaj, DACoutput=3V/4095 = 732,600732
  Örneğin 1V elde etmek isteniyorsa:, 1/0,000732600 = 1365 değeri elde edilir.

#### Çalışma Modları

- STM32 mikrodenetleyicilerinde DAC modülü genellikle tek kanal, çift kanal, üçgen dalga ve gürültü oluşturma modları gibi farklı çalışma modlarına sahiptir.
- **Tek Kanal Modu**, Tek bir DAC kanalı üzerinden analog çıkış sağlar. Örneğin, STM32 mikrodenetleyicilerinde "DAC\_Channel\_1" kullanarak tek kanal modunda DAC'ı kullanabilirsiniz.
- Çift Kanal Modu, iki DAC kanalı üzerinden bağımsız olarak analog çıkış sağlar. Örneğin, STM32 mikrodenetleyicilerinde "DAC\_Channel\_1" ve "DAC\_Channel\_2" kullanarak çift kanal modunda DAC'ı kullanabilirsiniz.
- Üçgen Dalga Modu, DAC, üçgen dalga formunu üretebilir. Bu modda, DAC çıkışı belirli bir frekansta bir üçgen dalga formunu takip eder.
- **Gürültü Oluşturma Modu**, DAC, belirli bir frekansta gürültü sinyali üretebilir. Bu modda, DAC çıkışı belirli bir frekansta rasgele değerler üreterek bir gürültü sinyali oluşturur.

#### Tetikleme İslemleri

- Genellikle yazılımsal ve harici tetikleme (triggering) yöntemleri ile kullanılabilir. Bu yöntemler, DAC'nin çıkışını kontrol etmek ve çıkış verisini belirli bir zamanlama veya olaya bağlamak için kullanılır.
- Software Triggering, Yazılımsal tetikleme, mikrodenetleyici yazılımı tarafından kontrol edilen bir tetikleme yöntemidir. Yazılım, DAC çıkışını başlatmak veya durdurmak için özel bir komut kullanır. Bu yöntem, zamanlama ile ilgili hassas kontrol gerektiren durumlarda kullanışlıdır. Örneğin, bir zamanlayıcı kesmesi veya belirli bir durum gerçekleştiğinde DAC çıkışını güncellemek için yazılımsal tetikleme kullanılabilir.
- External Triggering, DAC modülünü dış bir olaya (örneğin, bir zamanlayıcı kesmesi, bir GPIO değişikliği veya başka bir harici sinyal) bağlamak anlamına gelir. Harici bir sinyal algılandığında veya belirli bir durum gerçekleştiğinde, DAC çıkışını güncellemek için harici bir sinyal kullanılabilir.

## Farklılıkları

- DAC ve PWM, her ikisi de dijital sinyalleri analog sinyallere dönüştürmek için kullanılan yöntemlerdir, ancak farklı çalışma prensiplerine sahiptirler.
- DAC, doğrudan dijital değerleri analog voltaj veya akıma dönüştürürken, PWM, darbe genişliği modülasyonu yoluyla bir analog etki oluşturur.
- DAC, genellikle doğrudan analog çıkış sağlar ve daha hassas bir çözünürlük sunabilir. PWM ise daha çok göreceli ve yaklaşık bir çözünürlük sağlar.
- DAC, genellikle özel bir entegre devre içerirken, PWM, genellikle bir mikrodenetleyici tarafından kontrol edilir.
- DAC, yüksek hassasiyet gerektiren ses uygulamalarında daha tercih edilebilirken, PWM, motor hız kontrolü gibi uygulamalarda daha uygun olabilir.

## **Birim Yapısı**



## Register

| Offset | Register        | 31                                | 30       | 29 | 28 | 27 | 26         | 25 | 24 | 23 | 22         | 21 | 20   | 19             | 80             | 17             | 16             | 15        | 4         | 13         | 12     | +             | 9        | 6          | æ                     | 1 | 9 |     | 0     | 4     | 20  | + | • |
|--------|-----------------|-----------------------------------|----------|----|----|----|------------|----|----|----|------------|----|------|----------------|----------------|----------------|----------------|-----------|-----------|------------|--------|---------------|----------|------------|-----------------------|---|---|-----|-------|-------|-----|---|---|
| 0×00   | DAC_CR          | Reserved<br>DIMAUDRIEZ<br>DIMAENZ |          |    |    |    | MAMP2[3:0] |    |    |    | WAVE TSEL2 |    |      | [2:0]          | TEN2           | BOFF2          | EN2            | Besterand | NON LOCAL | DIMAUDRIET | DMAEN1 | MAMP1[3:0]    |          | :0]        | WAVE TSE<br>1[2:0] :0 |   |   | L1[ | 2 191 | BOFF1 | EN1 |   |   |
| 0x04   | DAC_<br>SWTRIGR | Reserved                          |          |    |    |    |            |    |    |    |            |    |      |                |                |                |                |           |           |            |        |               | SWTRIG2  | SWTRIG1    |                       |   |   |     |       |       |     |   |   |
| 0x08   | DAC_<br>DHR12R1 | Reserved                          |          |    |    |    |            |    |    |    |            |    |      |                |                | DACC1DHR[11:0] |                |           |           |            |        |               |          |            |                       |   |   |     |       |       |     |   |   |
| 0x0C   | DAC_<br>DHR12L1 | Reserved                          |          |    |    |    |            |    |    |    |            |    |      |                | DACC1DHR[11:0] |                |                |           |           |            |        |               | Reserved |            |                       |   |   |     |       |       |     |   |   |
| 0x10   | DAC_<br>DHR8R1  | Reserved                          |          |    |    |    |            |    |    |    |            |    |      |                |                |                | DACCIDHR[7:0]  |           |           |            |        |               |          |            |                       |   |   |     |       |       |     |   |   |
| 0x14   | DAC_<br>DHR12R2 | Reserved                          |          |    |    |    |            |    |    |    |            |    |      |                |                | DACC2DHR[11:0] |                |           |           |            |        |               |          |            |                       |   |   |     |       |       |     |   |   |
| 0x18   | DAC<br>DHR12L2  | Reserved                          |          |    |    |    |            |    |    |    |            |    |      | DACC2DHR[11:0] |                |                |                |           |           |            |        |               | Reserved |            |                       |   |   |     |       |       |     |   |   |
| 0x1C   | DAC<br>DHR8R2   | Reserved                          |          |    |    |    |            |    |    |    |            |    |      |                | DACC           |                |                |           |           |            |        |               | cc       | C2DHR[7:0] |                       |   |   |     |       |       |     |   |   |
| 0x20   | DAC_<br>DHR12RD | Reserved DAGC2DHR[11:0]           |          |    |    |    |            |    |    |    |            |    | F    | Rese           | rve            | d              | DACC1DHR[11:0] |           |           |            |        |               |          |            |                       |   |   |     |       |       |     |   |   |
| 0x24   | DAC_<br>DHR12LD | DACC2DHR[11:0]                    |          |    |    |    |            |    |    |    |            | F  | Rese | erve           | d              | DACC1DHR(      |                |           |           |            |        | Ę11           | :0]      |            |                       |   | T | Res | erv   | ed    |     |   |   |
| 0x28   | DAC_<br>DHR8RD  | Reserved                          |          |    |    |    |            |    |    |    |            |    |      | DACC2DHR[7:0]  |                |                |                |           |           |            |        | DACC1DHR[7:0] |          |            |                       |   |   |     |       |       |     |   |   |
| 0x2C   | DAC_<br>DOR1    |                                   | Reserved |    |    |    |            |    |    |    |            |    |      |                |                |                | DACC1DOR(11:0) |           |           |            |        |               |          |            |                       |   |   |     |       |       |     |   |   |
| 0x30   | DAC_<br>DOR2    |                                   | Reserved |    |    |    |            |    |    |    |            |    |      |                | DACC2DOR[11:0] |                |                |           |           |            |        |               |          |            |                       | _ |   |     |       |       |     |   |   |
| 0x34   | DAC_SR          | Baserved Reserved                 |          |    |    |    |            |    |    |    |            |    |      |                | Reserved       |                |                |           |           |            |        |               |          |            |                       |   |   |     |       |       |     |   |   |

- DAC\_CR (Control Register), DAC'nin genel kontrolünü sağlayan bu register, örneğin çıkış voltaj seviyesi, çıkış güçlendirme ve trigger seçeneklerini içerir.
  - EN1 (Bit 0): DAC kanal 1 etkin
    - 0: Devre dışı
    - 1: Etkin
  - BOFF1 (Bit 1): Output buffer kontrolü
    - 0: Buffer etkin
    - 1: Buffer devre dışı (düşük empedans çıkış için)

- TEN1 (Bit 2): Trigger etkinleştirme
  - 0: Yazılımsal tetikleme
  - 1: Harici trigger etkin
- TSEL1[5:3]: Trigger kaynak seçimi
  - 000: TIM6 TRGO
  - 001: TIM3 TRGO
  - 010: TIM7 TRGO
  - 011: TIM5 TRGO
  - 100: TIM2 TRGO
  - 101: TIM4 TRGO
  - 110: EXTI9
  - 111: Yazılımsal trigger
- WAVE1[7:6]: Wave generation modu
  - 00: None
  - 01: Noise
  - 10: Triangle
  - 11: Reserved
- MAMP1[11:8]: Amplitüd değeri (noise veya triangle modu için)
- DMAEN1 (Bit 12): DMA modu etkinliği
  - 1: DMA ile veri yazılabilir
- DAC\_SWTRIGR (Software Trigger Register), yazılım tetikleme işlemlerini kontrol etmek için kullanılır.
  - SWTRIG1 (Bit 0): Kanal 1 için yazılım tetikleme
  - SWTRIG2 (Bit 1): Kanal 2 için yazılım tetikleme
    - 1: Dönüşüm başlatılır (TENx aktifse trigger yerine geçer)
- DAC\_DHR (Data Holding Register), bu register'lar, DAC'ye gönderilecek dijital veriyi içerir.
  - DACC1DHR[11:0]: DAC kanal 1 için dijital veri
  - DACC2DHR[11:0]: DAC kanal 2 için dijital veri
- DAC\_SR (Status Register), DAC durumunu izlemek için kullanılır.
  - DMAUDR1 / DMAUDR2 (Bit 13/29): DMA underrun flag
    - 1: DAC yeni veri gelmeden eski veriyi kullandı → hata olabilir. Temizlemek için ilgili bitlere 1 vazılır.
- **DAC\_DOR** (Data Output Register), DAC'nin çıkışından okunan gerçek zamanlı dijital çıkış verisini temsil eder. Dönüştürülen analog sinyalin temsil ettiği dijital değeri içerir.
  - DACC1DOR[11:0]: Analog çıkışa karşılık gelen en son dijital değer